import logging
import os
import time

from utils.get_filepath import get_log_path

log_path = get_log_path()
if not os.path.exists(log_path):
    os.mkdir(log_path)


class Logger:
    def __init__(self):
        # 定义日志位置和文件名
        self.logname = os.path.join(log_path, "{0}.log".format(time.strftime("%Y-%m-%d")))
        # 定义一个日志容器
        self.logger = logging.getLogger("log")
        # 设置日志级别
        self.logger.setLevel(logging.DEBUG)

        # 创建日志输入的格式   时间-文件名-行数-日志级别-日志信息
        self.formatter = logging.Formatter("[%(asctime)s][%(filename)s %(lineno)d][%(levelname)s]: %(message)s")
        # 创建日志处理器，用来存放日志文件 a代表是追加的意思
        self.filelogger = logging.FileHandler(self.logname, mode='a', encoding='UTF-8')
        # 创建日志处理器，在控制台打印
        self.console = logging.StreamHandler()
        # 设置控制台打印日志级别
        self.console.setLevel(logging.DEBUG)
        # 文件存放日志级别
        self.filelogger.setLevel(logging.DEBUG)
        # 文件存放日志格式
        self.filelogger.setFormatter(self.formatter)
        # 控制台打印日志格式
        self.console.setFormatter(self.formatter)
        # 将日志输出渠道添加到日志收集器中
        self.logger.addHandler(self.filelogger)
        self.logger.addHandler(self.console)


logger = Logger().logger
if __name__ == '__main__':
    logger.debug("我打印debug日志")
    logger.info("我打印info日志")
    logger.error("我打印error日志")
    logger.warning("我打印warning日志")
